/****************************************************************************
 * arch/arm/src/kinetis/hardware/kinetis_k66memorymap.h
 *
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.  The
 * ASF licenses this file to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance with the
 * License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the
 * License for the specific language governing permissions and limitations
 * under the License.
 *
 ****************************************************************************/

#ifndef __ARCH_ARM_SRC_KINETIS_HARDWARE_KINETIS_K66MEMORYMAP_H
#define __ARCH_ARM_SRC_KINETIS_HARDWARE_KINETIS_K66MEMORYMAP_H

/****************************************************************************
 * Included Files
 ****************************************************************************/

#include <nuttx/config.h>

#include "chip.h"

#ifdef KINETIS_K66

/****************************************************************************
 * Pre-processor Definitions
 ****************************************************************************/

/* Memory Map ***************************************************************/

/* K66 Family
 *
 * The memory map for the following parts is defined in NXP document
 * K66P144M180SF5RMV2 Rev. 2, May 2015
 */

#if defined(CONFIG_ARCH_CHIP_MK66FN2M0VMD18) || defined(CONFIG_ARCH_CHIP_MK66FX1M0VMD18) || \
      defined(CONFIG_ARCH_CHIP_MK66FN2M0VLQ18) || defined(CONFIG_ARCH_CHIP_MK66FX1M0VLQ18)

# define KINETIS_FLASH_BASE         0x00000000 /* -0x07ffffff Program flash and read-
                                                *             only data (Includes exception
                                                *             vectors in first 1024 bytes) */

# define KINETIS_SDRAMALIAS_BASE    0x08000000 /* -0x0fffffff SDRAM (Aliased area). mapped
                                                *             to same space of 0x88000000 -
                                                *             0x8FFF_FFFF. See bit31 of
                                                *             SDRAMC */
# if defined(KINETIS_FLEXMEM_SIZE)
#  define KINETIS_FLEXNVM_BASE      0x10000000 /* -0x13ffffff FlexNVM */
#  define KINETIS_FLEXRAM_BASE      0x14000000 /* -0x17ffffff FlexRAM */
# else
#  define KINETIS_PRGACCLRAM_BASE   0x14000000 /* -0x17ffffff For devices with program flash
                                                *             only: Programming acceleration
                                                *             RAM */
# endif
# define KINETIS_FBALIAS_BASE      0x18000000  /* -0x1bffffff FlexBus (Aliased Area). mapped
                                                *             to same space of 0x9800_0000 -
                                                *             0x9BFF_FFFF. See bit31 of
                                                *             FlexBus chip select */
# define KINETIS_SRAML_BASE         0x1c000000 /* -0x1fffffff SRAM_L: Lower SRAM
                                                *             (ICODE/DCODE) */
# define KINETIS_SRAMU_BASE         0x20000000 /* -0x200fffff SRAM_U: Upper SRAM bitband
                                                *             region */

                             /*     0x20100000  * -0x21ffffff Reserved */
# define KINETIS_SALIAS_BASE        0x22000000 /* -0x23ffffff Aliased to SRAM_U bitband */

                             /*     0x24000000  * -0x2fffffff Reserved */
# define KINETIS_FDATALIAS_BASE     0x30000000 /* -0x33ffffff Flash Data Alias */
# define KINETIS_FLEXNVMCO_BASE     0x34000000 /* -0x3fffffff FlexNVM Cortex-M4 core only */
# define KINETIS_BRIDGE0_BASE       0x40000000 /* -0x4007ffff Bitband region for peripheral
                                                *             bridge 0 (AIPS-Lite0) */
# define KINETIS_BRIDGE1_BASE       0x40080000 /* -0x400fffff Bitband region for peripheral
                                                *             bridge 1 (AIPS-Lite1) */
# define KINETIS_GPIOBB_BASE        0x400ff000 /* -0x400fffff Bitband region for general
                                                *             purpose input/output (GPIO) */

                             /*     0x40100000  * -0x41ffffff Reserved */
# define KINETIS_PALIAS_BASE        0x42000000 /* -0x43ffffff Aliased to peripheral bridge
                                                *             (AIPS-Lite) and general purpose
                                                *             input/output (GPIO) bitband */

                             /*     0x44000000  * -0x5fffffff Reserved */
# define KINETIS_FLEXBUS_BASE       0x60000000 /* -0x7fffffff FlexBus (External Memory - Write-back) */
# define KINETIS_SDRAMWB_BASE       0x70000000 /* -0x7fffffff SDRAM (External RAM - Write-back) */
# define KINETIS_SDRAMWT_BASE       0x80000000 /* -0x8fffffff SDRAM (External RAM - Write-through) */
# define KINETIS_FLEXBUSWT_BASE     0x90000000 /* -0x9fffffff FlexBus (External RAM - Write-through) */
# define KINETIS_FLEXBUSEP_BASE     0xa0000000 /* -0xdfffffff FlexBus External Peripheral - Not executable)*/
# define KINETIS_PERIPH_BASE        0xe0000000 /* -0xe00fffff Private peripherals */

                             /*     0xe0100000  * -0xffffffff Reserved */

/* Peripheral Bridge 0 Memory Map *******************************************/

# define KINETIS_AIPS0_BASE         0x40000000 /* Peripheral bridge 0 (AIPS-Lite 0) */
# define KINETIS_XBAR_BASE          0x40004000 /* Crossbar switch */
# define KINETIS_DMAC_BASE          0x40008000 /* DMA controller */
# define KINETIS_DMADESC_BASE       0x40009000 /* DMA controller transfer control descriptors */
# define KINETIS_FLEXBUSC_BASE      0x4000c000 /* FlexBus controller */
# define KINETIS_MPU_BASE           0x4000d000 /* MPU */
# define KINETIS_SDRAMC_BASE        0x4000f000 /* SDRAMC */
# define KINETIS_FMC_BASE           0x4001f000 /* Flash memory controller */
# define KINETIS_FTFE_BASE          0x40020000 /* Flash memory */
# define KINETIS_DMAMUX0_BASE       0x40021000 /* DMA channel multiplexer 0 */
# define KINETIS_CAN0_BASE          0x40024000 /* FlexCAN 0 */
# define KINETIS_RNGA_BASE          0x40029000 /* Random Number Generator (RNGA) */
# define KINETIS_SPI0_BASE          0x4002c000 /* DSPI 0 */
# define KINETIS_SPI1_BASE          0x4002d000 /* DSPI 1 */
# define KINETIS_I2S0_BASE          0x4002f000 /* I2S 0 */
# define KINETIS_CRC_BASE           0x40032000 /* CRC */
# define KINETIS_USBDCD_BASE        0x40035000 /* USB DCD */
# define KINETIS_PDB0_BASE          0x40036000 /* Programmable delay block */
# define KINETIS_PIT_BASE           0x40037000 /* Periodic interrupt timers (PIT) */
# define KINETIS_FTM0_BASE          0x40038000 /* FlexTimer (FTM) 0 */
# define KINETIS_FTM1_BASE          0x40039000 /* FlexTimer (FTM) 1 */
# define KINETIS_FTM2_BASE          0x4003a000 /* FlexTimer (FTM) 2 */
# define KINETIS_ADC0_BASE          0x4003b000 /* Analog-to-digital converter (ADC) 0 */
# define KINETIS_RTC_BASE           0x4003d000 /* Real time clock */
# define KINETIS_VBATR_BASE         0x4003e000 /* VBAT register file */
# define KINETIS_DAC0_BASE          0x4003f000 /* DAC0 */
# define KINETIS_LPTMR0_BASE        0x40040000 /* Low power timer 0 */
# define KINETIS_SYSR_BASE          0x40041000 /* System register file */
# define KINETIS_TSI0_BASE          0x40045000 /* Touch sense interface */
# define KINETIS_SIMLP_BASE         0x40047000 /* SIM low-power logic */
# define KINETIS_SIM_BASE           0x40048000 /* System integration module (SIM) */
# define KINETIS_PORT_BASE(n)       (0x40049000 + ((n) << 12))
# define KINETIS_PORTA_BASE         0x40049000 /* Port A multiplexing control */
# define KINETIS_PORTB_BASE         0x4004a000 /* Port B multiplexing control */
# define KINETIS_PORTC_BASE         0x4004b000 /* Port C multiplexing control */
# define KINETIS_PORTD_BASE         0x4004c000 /* Port D multiplexing control */
# define KINETIS_PORTE_BASE         0x4004d000 /* Port E multiplexing control */
# define KINETIS_WDOG_BASE          0x40052000 /* Software watchdog */
# define KINETIS_EWM_BASE           0x40061000 /* External watchdog */
# define KINETIS_CMT_BASE           0x40062000 /* Carrier modulator timer (CMT) */
# define KINETIS_MCG_BASE           0x40064000 /* Multi-purpose Clock Generator (MCG) */
# define KINETIS_OSC_BASE           0x40065000 /* System oscillator (XOSC) */
# define KINETIS_I2C0_BASE          0x40066000 /* I2C 0 */
# define KINETIS_I2C1_BASE          0x40067000 /* I2C 1 */
# define KINETIS_UART0_BASE         0x4006a000 /* UART0 */
# define KINETIS_UART1_BASE         0x4006b000 /* UART1 */
# define KINETIS_UART2_BASE         0x4006c000 /* UART2 */
# define KINETIS_UART3_BASE         0x4006d000 /* UART3 */
# define KINETIS_USB0_BASE          0x40072000 /* USB OTG FS/LS */
# define KINETIS_CMP_BASE           0x40073000 /* Analog comparator (CMP) / 6-bit digital-to-analog converter (DAC) */
# define KINETIS_VREF_BASE          0x40074000 /* Voltage reference (VREF) */
# define KINETIS_LLWU_BASE          0x4007c000 /* Low-leakage wakeup unit (LLWU) */
# define KINETIS_PMC_BASE           0x4007d000 /* Power management controller (PMC) */
# define KINETIS_SMC_BASE           0x4007e000 /* System Mode controller (SMC) */
# define KINETIS_RCM_BASE           0x4007f000 /* Reset Control Module (RCM) */

/* Peripheral Bridge 1 Memory Map *******************************************/

# define KINETIS_AIPS1_BASE         0x40080000 /* Peripheral bridge 1 (AIPS-Lite 1) */
# define KINETIS_RNGA_ALT_BASE      0x400a0000 /* Alternate address Random number generator (RNGA) */
# define KINETIS_USBHS_BASE         0x400a1000 /* USB OTG HS/FS/LS */
# define KINETIS_USBHSPHY_BASE      0x400a2000 /* USBHS PHY */
# define KINETIS_USBHSDCD_BASE      0x400a3000 /* USBHS DCD */
# define KINETIS_CAN1_BASE          0x400a4000 /* FlexCAN 1 */
# define KINETIS_SPI2_BASE          0x400ac000 /* DSPI 2 */
# define KINETIS_SDHC_BASE          0x400b1000 /* eSDHC */
# define KINETIS_FTM2_ALT_BASE      0x400b8000 /* Alternate address FlexTimer 2 */
# define KINETIS_FTM3_BASE          0x400b9000 /* FlexTimer 3 */
# define KINETIS_ADC1_BASE          0x400bb000 /* Analog-to-digital converter (ADC) 1 */
# define KINETIS_EMAC_BASE          0x400c0000 /* Ethernet MAC and IEEE 1588 timers */
# define KINETIS_LPUART0_BASE       0x400c4000 /* LPUART0 */
# define KINETIS_TPM1_BASE          0x400c9000 /* TPM1 */
# define KINETIS_TPM2_BASE          0x400ca000 /* TPM2 */
# define KINETIS_DAC0_ALT_BASE      0x400cc000 /* Alternate address 12-bit digital-to-analog converter (DAC) 0 */
# define KINETIS_DAC1_BASE          0x400cd000 /* 12-bit digital-to-analog converter (DAC) 1 */
# define KINETIS_I2C2_BASE          0x400e6000 /* I2C 2 */
# define KINETIS_I2C3_BASE          0x400e7000 /* I2C 3 */
# define KINETIS_UART4_BASE         0x400ea000 /* UART4 */
# define KINETIS_XBARSS_BASE        0x400ff000 /* Not an AIPS-Lite slot. The 32-bit general
                                                * purpose input/output module that shares the
                                                * crossbar switch slave port with the AIPS-Lite
                                                * is accessed at this address. */
# define KINETIS_GPIO_BASE(n)       (0x400ff000 + ((n) << 6))
# define KINETIS_GPIOA_BASE         0x400ff000 /* GPIO PORTA registers */
# define KINETIS_GPIOB_BASE         0x400ff040 /* GPIO PORTB registers */
# define KINETIS_GPIOC_BASE         0x400ff080 /* GPIO PORTC registers */
# define KINETIS_GPIOD_BASE         0x400ff0c0 /* GPIO PORTD registers */
# define KINETIS_GPIOE_BASE         0x400ff100 /* GPIO PORTE registers */

/* Private Peripheral Bus (PPB) Memory Map **********************************/

# define KINETIS_ITM_BASE           0xe0000000 /* Instrumentation Trace Macrocell (ITM) */
# define KINETIS_DWT_BASE           0xe0001000 /* Data Watchpoint and Trace (DWT) */
# define KINETIS_FPB_BASE           0xe0002000 /* Flash Patch and Breakpoint (FPB) */
# define KINETIS_SCS_BASE           0xe000e000 /* System Control Space (SCS) (for NVIC) */
# define KINETIS_TPIU_BASE          0xe0040000 /* Trace Port Interface Unit (TPIU) */
# define KINETIS_ETM_BASE           0xe0041000 /* Embedded Trace Macrocell (ETM) */
# define KINETIS_ETB_BASE           0xe0042000 /* Embedded Trace Buffer (ETB) */
# define KINETIS_TFUN_BASE          0xe0043000 /* Embedded Trace Funnel */
# define KINETIS_MCM_BASE           0xe0080000 /* Miscellaneous Control Module (including ETB Almost Full) */
# define KINETIS_MMCAU_BASE         0xe0081000 /* Memory Mapped Cryptographic Acceleration Unit (MMCAU) */
# define KINETIS_CACHECTL_BASE      0xe0082000 /* Cache Controller */
# define KINETIS_ROMTAB_BASE        0xe00ff000 /* ROM Table - allows auto-detection of debug components */

#else
  /* The memory map for other parts is defined in other documents and may or
   * may not be the same as above (the family members are all very similar)
   * This error just means that you have to look at the document and
   * determine for yourself if the memory map is the same.
   */

#  error "No memory map for this K66 part"
#endif

/****************************************************************************
 * Public Types
 ****************************************************************************/

/****************************************************************************
 * Public Data
 ****************************************************************************/

/****************************************************************************
 * Public Functions Prototypes
 ****************************************************************************/

#endif /* KINETIS_K66 */
#endif /* __ARCH_ARM_SRC_KINETIS_HARDWARE_KINETIS_K66MEMORYMAP_H */
